<!DOCTYPE html>
<html lang="zh-CN">
  <head>
  <meta charset="UTF-8">
  <meta 
    name="viewport"
    content="width=device-width, initial-scale=1.0, minimum-scale=1.0">
  <meta 
    http-equiv="X-UA-Compatible" 
    content="ie=edge">
  <meta 
    name="theme-color" 
    content="#fff" 
    id="theme-color">
  <meta 
    name="description" 
    content="hexoDemo用于介绍如何使用hexo">
  <link 
    rel="icon" 
    href="/">
  <title>00-前端性能优化认知</title>
  
    
      <meta 
        property="og:title" 
        content="00-前端性能优化认知">
    
    
      <meta 
        property="og:url" 
        content="https://zwl5670.gitee.io/2014/08/01/14-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/00-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5/index.html">
    
    
      <meta 
        property="og:img" 
        content="https://img.songhn.com/img/Y67gdd.png">
    
    
      <meta 
        property="og:img" 
        content="hexoDemo用于介绍如何使用hexo">
    
    
      <meta 
        property="og:type" 
        content="article">
      <meta 
        property="og:article:published_time" 
        content="2014-08-01">
      <meta 
        property="og:article:modified_time" 
        content="2023-03-14">
      <meta 
        property="og:article:author" 
        content="zwl5670">
      
        
          <meta 
            property="og:article:tag" 
            content="性能优化">
        
      
    
  
  
  <link rel="preload" href="//at.alicdn.com/t/font_1946621_i1kgafibvw.css" as="style" >
  <link rel="preload" href="//at.alicdn.com/t/font_1952792_89b4ac4k4up.css" as="style" >
  <link rel="preload" href="/css/main.css" as="style" >
  
  <link rel="modulepreload" href="//instant.page/5.1.0">
  
  <link rel="stylesheet" href="/css/main.css">
  
  <link rel="stylesheet" href="//at.alicdn.com/t/font_1946621_i1kgafibvw.css">
  
  <link rel="stylesheet" href="//at.alicdn.com/t/font_1952792_89b4ac4k4up.css">
  
  
  
    <link rel="stylesheet" href="/js/lib/lightbox/baguetteBox.min.css">
  
  <script>
    function loadScript(url, cb) {
      var script = document.createElement('script');
      script.src = url;
      if (cb) script.onload = cb;
      script.async = true;
      document.body.appendChild(script);
    }
    function loadCSS(href, data, attr) {
      var sheet = document.createElement('link');
      sheet.ref = 'stylesheet';
      sheet.href = href;
      sheet.dataset[data] = attr;
      document.head.appendChild(sheet);
    }
    function changeCSS(cssFile, data, attr) {
      var oldlink = document.querySelector(data);
      var newlink = document.createElement("link");
      newlink.setAttribute("rel", "stylesheet");
      newlink.setAttribute("href", cssFile);
      newlink.dataset.prism = attr;
      document.head.replaceChild(newlink, oldlink);
    }
  </script>
  
    
  
  <script>
    // control reverse button
    var reverseDarkList = {
      dark: 'light',
      light: 'dark'
    };
    var themeColor = {
      dark: '#1c1c1e',
      light: '#fff'
    }
    // get the data of css prefers-color-scheme
    var getCssMediaQuery = function() {
      return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
    };
    // reverse current darkmode setting function
    var reverseDarkModeSetting = function() {
      var setting = localStorage.getItem('user-color-scheme');
      if(reverseDarkList[setting]) {
        setting = reverseDarkList[setting];
      } else if(setting === null) {
        setting = reverseDarkList[getCssMediaQuery()];
      } else {
        return;
      }
      localStorage.setItem('user-color-scheme', setting);
      return setting;
    };
    // apply current darkmode setting
  </script>
  
    <script>
      var setDarkmode = function(mode) {
      var setting = mode || localStorage.getItem('user-color-scheme');
      if(setting === getCssMediaQuery()) {
        document.documentElement.removeAttribute('data-user-color-scheme');
        localStorage.removeItem('user-color-scheme');
        document.getElementById('theme-color').content = themeColor[setting];
        document.getElementById('theme-color').dataset.mode = setting;
      } else if(reverseDarkList[setting]) {
        document.documentElement.setAttribute('data-user-color-scheme', setting);
        document.getElementById('theme-color').content = themeColor[setting];
        document.getElementById('theme-color').dataset.mode = setting;
      } else {
        document.documentElement.removeAttribute('data-user-color-scheme');
        localStorage.removeItem('user-color-scheme');
        document.getElementById('theme-color').content = themeColor[getCssMediaQuery()];
        document.getElementById('theme-color').dataset.mode = getCssMediaQuery();
      }
    };
    setDarkmode();
    </script>
  
  
  
    <link rel="preload" href="/js/lib/lightbox/baguetteBox.min.js" as="script">
    <link rel="preload" href="/js/lib/lightbox/baguetteBox.min.css" as="style" >
  
  
    <link rel="preload" href="/js/lib/lozad.min.js" as="script">
  
  
  
  
  
  
<meta name="generator" content="Hexo 6.3.0"></head>

  <body>
    <div class="wrapper">
       
      <nav class="navbar">
  <div class="navbar-logo">
    <a class="navbar-logo-main" href="/">
      
      <span class="navbar-logo-dsc">前端面试</span>
      </a>
  </div>
  <div class="navbar-menu">
    
      <a 
        href="/" 
        class="navbar-menu-item">
        
          首页
        
      </a>
    
      <a 
        href="/archives" 
        class="navbar-menu-item">
        
          归档
        
      </a>
    
      <a 
        href="/tags" 
        class="navbar-menu-item">
        
          标签
        
      </a>
    
      <a 
        href="/categories" 
        class="navbar-menu-item">
        
          分类
        
      </a>
    
      <a 
        href="/about" 
        class="navbar-menu-item">
        
          关于
        
      </a>
    
      <a 
        href="/links" 
        class="navbar-menu-item">
        
          友链
        
      </a>
    
    <button 
      class="navbar-menu-item darknavbar navbar-menu-btn" 
      aria-label="Toggle dark mode"
      id="dark">
      <i class="iconfont icon-weather"></i>
    </button>
    <button 
      class="navbar-menu-item searchnavbar navbar-menu-btn" 
      aria-label="Toggle search"
      id="search">
      <!-- <i 
        class="iconfont icon-search" 
        style="font-size: 1.2rem; font-weight: 400;">
      </i> -->
      <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img"
        class="iconify iconify--ion" width="28" height="28" preserveAspectRatio="xMidYMid meet" viewBox="0 0 512 512">
        <path fill="none" stroke="currentColor" stroke-miterlimit="10" stroke-width="28"
          d="M256 80a176 176 0 1 0 176 176A176 176 0 0 0 256 80Z"></path>
        <path fill="none" stroke="currentColor" stroke-miterlimit="10" stroke-width="28"
          d="M232 160a72 72 0 1 0 72 72a72 72 0 0 0-72-72Z"></path>
        <path fill="none" stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="28"
          d="M283.64 283.64L336 336"></path>
      </svg>
    </button>
  </div>
</nav> 
      
      <div 
        id="local-search" 
        style="display: none">
        <input
          class="navbar-menu-item"
          id="search-input"
          placeholder="请输入搜索内容..." />
        <div id="search-content"></div>
      </div>
      
      <div class="section-wrap">
        <div class="container">
          <div class="columns">
            <aside class="left-column">
              
              <div class="card card-author">
                
  <img 
    src="https://img.songhn.com/img/Y67gdd.png" 
    class="author-img"
    width="88"
    height="88"
    alt="author avatar">

<p class="author-name">zwl5670</p>
<p class="author-description">前端学习资料</p>
<div class="author-message">
  <a 
    class="author-posts-count" 
    href="/archives">
    <span>215</span>
    <span>文章</span>
  </a>
  <a 
    class="author-categories-count" 
    href="/categories">
    <span>14</span>
    <span>分类</span>
  </a>
  <a 
    class="author-tags-count" 
    href="/tags">
    <span>14</span>
    <span>标签</span>
  </a>
</div>

              </div>
               <div class="sticky-tablet">
  
  
    <article class="display-when-two-columns spacer">
      <div class="card card-content toc-card">
        <div class="toc-header">
  <i 
    class="iconfont icon-menu" 
    style="padding-right: 2px;">
  </i>目录
</div>
<ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5"><span class="toc-text">前端性能优化认知</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BB%80%E4%B9%88%E6%98%AF%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">什么是前端性能优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E9%87%8D%E8%A6%81%E6%80%A7%EF%BC%88%E7%A8%8B%E5%BA%8F%E5%91%98%E8%A7%92%E5%BA%A6%EF%BC%89"><span class="toc-text">性能优化的重要性（程序员角度）</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E9%9D%A2%E8%AF%95"><span class="toc-text">前端性能优化面试</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E6%84%8F%E4%B9%89"><span class="toc-text">性能优化的意义</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%9B%B8%E5%85%B3%E6%A1%88%E4%BE%8B"><span class="toc-text">相关案例</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E8%A1%A5%E5%85%85"><span class="toc-text">补充</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%A6%82%E4%BD%95%E5%AD%A6%E4%B9%A0%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">如何学习性能优化</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AD%A6%E4%B9%A0%E9%9A%BE%E7%82%B9"><span class="toc-text">学习难点</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BC%98%E5%8C%96%E6%A0%87%E5%87%86"><span class="toc-text">优化标准</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%8A%80%E6%9C%AF%E5%82%A8%E5%A4%87%E5%89%8D%E6%8F%90"><span class="toc-text">技术储备前提</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AF%BB%E6%89%BE%E6%80%A7%E8%83%BD%E7%93%B6%E9%A2%88"><span class="toc-text">寻找性能瓶颈</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%A7%BB%E5%8A%A8%E7%AB%AF%E6%8C%91%E6%88%98%E5%A4%9A"><span class="toc-text">移动端挑战多</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%94%B6%E8%8E%B7"><span class="toc-text">收获</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%85%A8%E8%BF%87%E7%A8%8B"><span class="toc-text">前端性能优化全过程</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E9%9D%99%E6%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">1、静态资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E9%A1%B5%E9%9D%A2%E6%B8%B2%E6%9F%93%E6%9E%B6%E6%9E%84%E8%AE%BE%E8%AE%A1%E5%8F%8A%E7%9B%B8%E5%85%B3%E7%9A%84%E6%8A%80%E6%9C%AF%E6%96%B9%E6%A1%88%E9%80%89%E5%9E%8B"><span class="toc-text">2、页面渲染架构设计及相关的技术方案选型</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E5%8E%9F%E7%94%9FApp%E4%BC%98%E5%8C%96%E3%80%81%E6%B7%B7%E5%90%88%E5%BC%80%E5%8F%91%E4%BC%98%E5%8C%96"><span class="toc-text">3、原生App优化、混合开发优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E6%9C%8D%E5%8A%A1%E7%AB%AF%E4%B8%8E%E7%BD%91%E7%BB%9C%E4%BC%98%E5%8C%96"><span class="toc-text">4、服务端与网络优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E7%A0%94%E5%8F%91%E6%B5%81%E7%A8%8B%E4%BC%98%E5%8C%96"><span class="toc-text">5、研发流程优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E5%85%A8%E9%93%BE%E8%B7%AF%E8%B4%A8%E9%87%8F%E7%9B%91%E6%8E%A7%E4%BD%93%E7%B3%BB%E5%BB%BA%E8%AE%BE"><span class="toc-text">6、全链路质量监控体系建设</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%8C%85%E6%8B%AC%E5%93%AA%E4%BA%9B%E6%96%B9%E9%9D%A2"><span class="toc-text">前端性能优化包括哪些方面</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E6%8C%87%E6%A0%87%E4%B8%8E%E6%B5%8B%E9%87%8F%E5%B7%A5%E5%85%B7"><span class="toc-text">1、性能优化指标与测量工具</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E6%B8%B2%E6%9F%93%E4%BC%98%E5%8C%96"><span class="toc-text">2、渲染优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E4%BB%A3%E7%A0%81%E4%BC%98%E5%8C%96"><span class="toc-text">3、代码优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">4、资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E6%9E%84%E5%BB%BA%E4%BC%98%E5%8C%96"><span class="toc-text">5、构建优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E4%BC%A0%E8%BE%93%E5%92%8C%E5%8A%A0%E8%BD%BD%E4%BC%98%E5%8C%96"><span class="toc-text">6、传输和加载优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#7%E3%80%81%E6%9B%B4%E5%A4%9A%E4%B8%BB%E6%B5%81%E4%BC%98%E5%8C%96%E6%96%B9%E6%A1%88"><span class="toc-text">7、更多主流优化方案</span></a></li></ol></li></ol>
      </div>
    </article>
  
  
  <article class="card card-content categories-widget">
    <div class="categories-card">
  <div class="categories-header">
    <i 
      class="iconfont icon-fenlei" 
      style="padding-right: 2px;">
    </i>分类
  </div>
  <div class="categories-list">
    
      <a href="/categories/%E5%89%8D%E7%AB%AF%E5%B7%A5%E5%85%B7/">
        <div class="categories-list-item">
          前端工具
          <span class="categories-list-item-badge">13</span>
        </div>
      </a>
    
      <a href="/categories/CSS%E5%9F%BA%E7%A1%80/">
        <div class="categories-list-item">
          CSS基础
          <span class="categories-list-item-badge">18</span>
        </div>
      </a>
    
      <a href="/categories/CSS%E8%BF%9B%E9%98%B6/">
        <div class="categories-list-item">
          CSS进阶
          <span class="categories-list-item-badge">9</span>
        </div>
      </a>
    
      <a href="/categories/HTML/">
        <div class="categories-list-item">
          HTML
          <span class="categories-list-item-badge">12</span>
        </div>
      </a>
    
      <a href="/categories/JS%E5%9F%BA%E7%A1%80/">
        <div class="categories-list-item">
          JS基础
          <span class="categories-list-item-badge">56</span>
        </div>
      </a>
    
      <a href="/categories/JS%E5%9F%BA%E7%A1%80ES6/">
        <div class="categories-list-item">
          JS基础ES6
          <span class="categories-list-item-badge">10</span>
        </div>
      </a>
    
      <a href="/categories/JS%E5%9F%BA%E7%A1%80%E5%BC%82%E6%AD%A5/">
        <div class="categories-list-item">
          JS基础异步
          <span class="categories-list-item-badge">11</span>
        </div>
      </a>
    
      <a href="/categories/JS%E8%BF%9B%E9%98%B6/">
        <div class="categories-list-item">
          JS进阶
          <span class="categories-list-item-badge">11</span>
        </div>
      </a>
    
      <a href="/categories/%E7%A7%BB%E5%8A%A8web/">
        <div class="categories-list-item">
          移动web
          <span class="categories-list-item-badge">3</span>
        </div>
      </a>
    
      <a href="/categories/CSS%E5%92%8CDOM/">
        <div class="categories-list-item">
          CSS和DOM
          <span class="categories-list-item-badge">6</span>
        </div>
      </a>
    
      <a href="/categories/Node/">
        <div class="categories-list-item">
          Node
          <span class="categories-list-item-badge">16</span>
        </div>
      </a>
    
      <a href="/categories/Vue%E5%9F%BA%E7%A1%80/">
        <div class="categories-list-item">
          Vue基础
          <span class="categories-list-item-badge">15</span>
        </div>
      </a>
    
      <a href="/categories/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/">
        <div class="categories-list-item">
          性能优化
          <span class="categories-list-item-badge">7</span>
        </div>
      </a>
    
      <a href="/categories/%E5%89%8D%E7%AB%AF%E5%B7%A5%E7%A8%8B%E5%8C%96/">
        <div class="categories-list-item">
          前端工程化
          <span class="categories-list-item-badge">8</span>
        </div>
      </a>
    
  </div>
</div>
  </article>
  
  <article class="card card-content tags-widget">
    <div class="tags-card">
  <div class="tags-header">
    <i 
      class="iconfont icon-biaoqian" 
      style="padding-right: 2px;">
    </i>热门标签
  </div>
  <div class="tags-list">
    
      <a 
        href="/tags/JS%E5%9F%BA%E7%A1%80/" 
        title="JS基础">
        <div class="tags-list-item">JS基础</div>
      </a>
    
      <a 
        href="/tags/CSS%E5%9F%BA%E7%A1%80/" 
        title="CSS基础">
        <div class="tags-list-item">CSS基础</div>
      </a>
    
      <a 
        href="/tags/Node/" 
        title="Node">
        <div class="tags-list-item">Node</div>
      </a>
    
      <a 
        href="/tags/Vue%E5%9F%BA%E7%A1%80/" 
        title="Vue基础">
        <div class="tags-list-item">Vue基础</div>
      </a>
    
      <a 
        href="/tags/%E5%89%8D%E7%AB%AF%E5%B7%A5%E5%85%B7/" 
        title="前端工具">
        <div class="tags-list-item">前端工具</div>
      </a>
    
      <a 
        href="/tags/HTML/" 
        title="HTML">
        <div class="tags-list-item">HTML</div>
      </a>
    
      <a 
        href="/tags/JS%E8%BF%9B%E9%98%B6/" 
        title="JS进阶">
        <div class="tags-list-item">JS进阶</div>
      </a>
    
      <a 
        href="/tags/JS%E5%9F%BA%E7%A1%80%E5%BC%82%E6%AD%A5/" 
        title="JS基础异步">
        <div class="tags-list-item">JS基础异步</div>
      </a>
    
      <a 
        href="/tags/JS%E5%9F%BA%E7%A1%80ES6/" 
        title="JS基础ES6">
        <div class="tags-list-item">JS基础ES6</div>
      </a>
    
      <a 
        href="/tags/CSS%E8%BF%9B%E9%98%B6/" 
        title="CSS进阶">
        <div class="tags-list-item">CSS进阶</div>
      </a>
    
      <a 
        href="/tags/%E5%89%8D%E7%AB%AF%E5%B7%A5%E7%A8%8B%E5%8C%96/" 
        title="前端工程化">
        <div class="tags-list-item">前端工程化</div>
      </a>
    
      <a 
        href="/tags/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/" 
        title="性能优化">
        <div class="tags-list-item">性能优化</div>
      </a>
    
      <a 
        href="/tags/CSS%E5%92%8CDOM/" 
        title="CSS和DOM">
        <div class="tags-list-item">CSS和DOM</div>
      </a>
    
      <a 
        href="/tags/%E7%A7%BB%E5%8A%A8web/" 
        title="移动web">
        <div class="tags-list-item">移动web</div>
      </a>
    
  </div>
</div>
  </article>
  
  
</div>
            </aside>
            <main class="main-column">
              
<article class="card card-content">
  <header>
    <h1 class="post-title">
      00-前端性能优化认知
    </h1>
  </header>
  <div class="post-meta post-show-meta">
    <time datetime="2014-07-31T16:00:00.000Z">
      <i 
        class="iconfont icon-calendar" 
        style="margin-right: 2px;">
      </i>
      <span>2014-08-01</span>
    </time>
    
      <span class="dot"></span>
      
        <a 
          href="/categories/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/" 
          class="post-meta-link">
          性能优化
        </a>
      
    
    
      <span class="dot"></span>
      <span>3k 字</span>
    
  </div>
  
    <div 
      class="post-meta post-show-meta" 
      style="margin-top: -10px;">
      <div style="display: flex; align-items: center;">
        <i 
          class="iconfont icon-biaoqian" 
          style="margin-right: 2px; font-size: 1.15rem;">
        </i>
        
          
          <a 
            href="/tags/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/" 
            class="post-meta-link">
            性能优化
          </a>
        
      </div>
    </div>
  
  </header>
  <div 
    id="section" 
    class="post-content">
    <p><ArticleTopAd></ArticleTopAd></p>
<h2 id="前端性能优化认知"><a href="#前端性能优化认知" class="headerlink" title="前端性能优化认知"></a>前端性能优化认知</h2><h3 id="什么是前端性能优化"><a href="#什么是前端性能优化" class="headerlink" title="什么是前端性能优化"></a>什么是前端性能优化</h3><p>通常来讲，前端性能优化是指：从用户开始访问网站到整个页面完整地展现出来的过程中，通过各种优化策略和优化方法，让页面加载得更快，让用户的操作相应更及时，给用户更好的使用体验。</p>
<p>优化是在做什么：</p>
<p><img  srcset="data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20300%20300'%3E%3C/svg%3E" data-src="http://img.smyhvae.com/20210115-1507.png" class="lozad post-image"src="http://img.smyhvae.com/20210115-1507.png"></p>
<p>如上图所示，优化工作是围绕前端的基本工作原理展开的，包括：<strong>客户端和服务器端建立连接、加载资源、解析资源并渲染</strong>。</p>
<p>上方图片的来源：</p>
<ul>
<li><a target="_blank" rel="noopener" href="https://medium.com/dev-channel/the-cost-of-javascript-84009f51e99e">The Cost Of JavaScript</a></li>
<li><a target="_blank" rel="noopener" href="https://github.com/dwqs/blog/issues/59">[译]JavaScript 的时间消耗</a></li>
</ul>
<h3 id="性能优化的重要性（程序员角度）"><a href="#性能优化的重要性（程序员角度）" class="headerlink" title="性能优化的重要性（程序员角度）"></a>性能优化的重要性（程序员角度）</h3><p>当领导问：“<strong>为什么网页访问这么慢</strong>？”我们不能只是回答“<strong>网络不好</strong>”这么简单，网络不可能一直都不好。</p>
<p>每个程序员如果想要成长，就不能回避“性能优化”这个话题。很多人写了多年的代码，一直在构建样式、写业务逻辑。但是平凡的程序员之路，何时才是尽头？前端职业发展的瓶颈在哪儿？怎么才能从团队中脱颖而出？如何区分出平凡程序员&#x2F;大牛程序员&#x2F;架构师的分水岭？</p>
<p>职场晋升时，我们也要想一想：大部分人都在写业务代码，和别人相比，我的核心竞争力在哪里？除了<strong>技术深度、前端工程化、综合素质</strong>之外，还有其他的吗？<strong>性能优化</strong>，绝对是不能忽视的一方面。而且它是贯穿于开发和维护的的全过程。</p>
<p>前端工程化是侧重于<strong>提效</strong>，具体包括编译打包发布流程、物料中心、组件化等；而前端性能优化是侧重于<strong>体验</strong>。</p>
<p>公司评价一个程序员的价值，不是加班越多越好，也不是代码量越多越好，而是看他<strong>是否能解决其他人解决不了的一些技术难题或者瓶颈</strong>。</p>
<p><strong>大家都知道性能优化很重要，但是落实到具体，怎么去优化</strong>？这就需要我们深入去了解前端技术背后的原理，学习一些主流的前端性能优化技术方案，掌握性能优化技术，提升Web性能，才能总结出相应的优化方案，而且需要多年的经验积累；进而到达前端技术圈的上游，提高自己的核心竞争力。</p>
<h3 id="前端性能优化面试"><a href="#前端性能优化面试" class="headerlink" title="前端性能优化面试"></a>前端性能优化面试</h3><p>性能优化是前端面试的必考问题，面试者在回答这个问题时，大致情况如下：</p>
<ul>
<li><p>70% 的人上来就说减少合并资源、减少请求、数据缓存这些优化手段。</p>
</li>
<li><p>15% 的人会提到需要在 DevTools 下先看看首屏时间，可以先围绕首屏来做优化。</p>
</li>
<li><p>10%的人会提到需要接入一个性能平台来看看现状，诊断一下。</p>
</li>
<li><p>而只有 5% 的人会从前端性能体系来系统考虑性能优化。</p>
</li>
</ul>
<p>面试官期待的是你在什么场景下，遇到了什么性能问题，围绕什么样的性能指标，采取了哪些性能优化手段，最后取得了什么样的结果，而不仅仅是直接说采取了哪些优化手段。</p>
<p>比如说，“<strong>为什么首页打开慢</strong>？”	面试官期待的是，前端能和后端一样，通过查日志和数据就能定位问题，而不是停留在猜测层面。但在实际当中，能做到这点的前端同学并不多。</p>
<p>那么，前端有没有这样的工具呢？有，那就是性能监控平台。平台上面有各个业务的性能指标及其对应场景下的性能标准，一旦遇到性能问题，就能直接判断当前性能数据有没有问题，然后提示问题是出在前端、后端，还是网络层。</p>
<h3 id="性能优化的意义"><a href="#性能优化的意义" class="headerlink" title="性能优化的意义"></a>性能优化的意义</h3><p>1、随着互联网的发展，<strong>网页的内容越来越丰富，功能越来越强大，页面也越做越漂亮</strong>；带来的问题是，访问速度和体验会收到影响。只有对网站进行持续不断的优化，才能保证网页的访问速度可以跟得上用户体验的需求。</p>
<p>2、<strong>高性能</strong>可以带来更高的<strong>用户参与度</strong>、<strong>用户留存</strong>，进而带来更高的<strong>转化率</strong>和<strong>SEO排名</strong>，更好的<strong>用户体验</strong>，最终带来更高的<strong>业务收益</strong>。</p>
<p>随着时间的推移，如果一个网站由于各种原因导致心梗越来越差，以至于用户每打开一个页面都要等待很长时间，甚至出现加载失败的情况，那么，不仅新用户不会沉淀下来，老用户也会纷纷离去，最终导致产品的加速衰败。</p>
<p>而且网站的加载快慢，最产品收入有着直接的影响。<strong>有数据表明：网页加载时间在5秒内的网站比加载时间为19秒的网站，广告收入会增加近一倍</strong>。也就是说，网站或者App的性能直接关系到产品的用户增长和收入增长。</p>
<p>正因为如此，我们才需要通过性能优化的技巧，并结合其他的技术手段来不断提高网站和App的用户体验，从而助力公司的业务增长；同时，我们也可以借此提升自己的技术实力，这对个人的职业成长也会以后很大的帮助。</p>
<p>3、只要产品上线了，随着<strong>业务规模量和用户访问量的扩大</strong>，性能优化就是不可回避的话题。在遇到性能问题时，有些人的解决办法是：用一些粗糙的手段把问题绕过去，但却给后面的人埋下了坑。这些人常说的依据口头禅是：</p>
<p><img  srcset="data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20300%20300'%3E%3C/svg%3E" data-src="http://img.smyhvae.com/20210115-2150.jpg" class="lozad post-image"src="http://img.smyhvae.com/20210115-2150.jpg"></p>
<h3 id="相关案例"><a href="#相关案例" class="headerlink" title="相关案例"></a>相关案例</h3><ul>
<li><p><a target="_blank" rel="noopener" href="https://www.gigaspaces.com/blog/amazon-found-every-100ms-of-latency-cost-them-1-in-sales/">Amazon发现每100ms延迟导致1%的销量损失</a>。</p>
</li>
<li><p>歌地图首页文件从100KB减少到70KB，流量在第一周涨了10%，在接下来的三周涨了25%。</p>
</li>
<li><p>腾讯根据长期数据监控发现，页面一秒钟延迟会造成页面访问量下降9.4%，跳出率增加8.3%，转化率下降3.5%。</p>
</li>
</ul>
<h3 id="补充"><a href="#补充" class="headerlink" title="补充"></a>补充</h3><p>有些同学做事有拖延症，经常喜欢刷朋友圈、刷微博、看新闻，导致工作效率很低。为了解决这个问题，其实有个办法就是：把你的浏览器或者指定的软件，添加一个5秒的延迟，这时候，当你访问所有的网站，都会很慢。坚持一个月，你会发现，你再也不想看这些网站了，工作效率明显提升了许多。</p>
<p>这件事情从侧面也反映出：网站的性能如果不够好，对用户来说是一种折磨。时间一长，用户就不想用这个网站了。性能和网站的利益直接相关。涉及到：流量、搜索、转化率、用户体验。</p>
<h2 id="如何学习性能优化"><a href="#如何学习性能优化" class="headerlink" title="如何学习性能优化"></a>如何学习性能优化</h2><h3 id="学习难点"><a href="#学习难点" class="headerlink" title="学习难点"></a>学习难点</h3><p>我们在网上找到的文章，有很多都只是对CSS、JS技术本身的优化，一旦涉及到App、后端、网络等不是很熟悉的领域，学习起来就比较困难了。结合具体业务开发的应用场景时，却不知从何下手。因此，<strong>我们需要要由点及面，学习全链路前端性能优化的知识体系和解决方案</strong>。</p>
<p>在实际工作当中，前端性能优化往往比较繁杂，学习难点主要体现在以下几个方面：todo</p>
<h3 id="优化标准"><a href="#优化标准" class="headerlink" title="优化标准"></a>优化标准</h3><p>我们在做优化时，需要有一个量化标准，比如：</p>
<ul>
<li><p>loading 要做到什么效果、动画要达到什么效果才是好的？</p>
</li>
<li><p>所有的事件处理，要在什么时间内完成，才能给用户良好的体验？</p>
</li>
</ul>
<h3 id="技术储备前提"><a href="#技术储备前提" class="headerlink" title="技术储备前提"></a>技术储备前提</h3><ul>
<li><p>掌握前端基础知识。</p>
</li>
<li><p>具备Web开发实战经验。</p>
</li>
</ul>
<h3 id="寻找性能瓶颈"><a href="#寻找性能瓶颈" class="headerlink" title="寻找性能瓶颈"></a>寻找性能瓶颈</h3><ul>
<li><p>了解性能指标，多快才算快。</p>
</li>
<li><p>利用测量工具和API</p>
</li>
<li><p>优化问题，重新测量。持续迭代。</p>
</li>
</ul>
<h3 id="移动端挑战多"><a href="#移动端挑战多" class="headerlink" title="移动端挑战多"></a>移动端挑战多</h3><ul>
<li><p>移动端的硬件不如PC端，且网络不稳定。</p>
</li>
<li><p>屏幕尺寸和交互方式都是挑战。</p>
</li>
<li><p>移动端用户更佳缺乏耐心。而且，很多用户是利用碎片化时间访问网页。数据参考： <strong>&gt;3秒</strong>的加载时间，导致 53%的跳出率（bounce rate）。</p>
</li>
<li><p>持续增长的移动端用户和电商业务。现在很多事情都是在移动端做的。</p>
</li>
</ul>
<h3 id="收获"><a href="#收获" class="headerlink" title="收获"></a>收获</h3><ul>
<li><p>由浅入深：解读优化技术内幕。</p>
</li>
<li><p>流行+经典：了解技术背后的设计思想。</p>
</li>
<li><p>了解性能优化的关键环节，升级知识储备。</p>
</li>
<li><p>理论+实践：掌握前端业界的流行且成熟的多种性能优化技术，脱颖而出。</p>
</li>
<li><p>了解大厂正在用的生产环境级别的高性能解决方案。</p>
</li>
</ul>
<h2 id="前端性能优化全过程"><a href="#前端性能优化全过程" class="headerlink" title="前端性能优化全过程"></a>前端性能优化全过程</h2><h3 id="1、静态资源优化"><a href="#1、静态资源优化" class="headerlink" title="1、静态资源优化"></a>1、静态资源优化</h3><p>静态资源优化包括html、css、js、图片等资源的性能优化。包括：</p>
<ul>
<li><p>图片的应用场景和使用</p>
</li>
<li><p>html、css、js的具体优化策略</p>
</li>
<li><p>资源文件的优化：比如文件压缩合并策略、打包方案、版本号更新方案</p>
</li>
<li><p>前端工程化工具等。</p>
</li>
</ul>
<h3 id="2、页面渲染架构设计及相关的技术方案选型"><a href="#2、页面渲染架构设计及相关的技术方案选型" class="headerlink" title="2、页面渲染架构设计及相关的技术方案选型"></a>2、页面渲染架构设计及相关的技术方案选型</h3><p>按照技术方案的分类，包括：</p>
<ul>
<li><p>前后端分离技术</p>
</li>
<li><p>SPA单页应用</p>
</li>
<li><p>BigPipe</p>
</li>
<li><p>同构直出</p>
</li>
<li><p>PWA</p>
</li>
<li><p>页面加载策略</p>
</li>
<li><p>接口服务调优、接口缓存策略</p>
</li>
<li><p>大型网站背后的实际性能优化案例</p>
</li>
<li><p>前端组件化、模块化，加速业务开发</p>
</li>
</ul>
<h3 id="3、原生App优化、混合开发优化"><a href="#3、原生App优化、混合开发优化" class="headerlink" title="3、原生App优化、混合开发优化"></a>3、原生App优化、混合开发优化</h3><ul>
<li><p>浏览器的整体优化方案。比如导航条、登录态、滚动条优化等。</p>
</li>
<li><p>前端缓存策略和优化</p>
</li>
<li><p>H5静态资源请求代理的技术原理</p>
</li>
<li><p>H5离线技术，达到页面秒开的目标</p>
</li>
<li><p>混合式开发解决方案</p>
</li>
<li><p>RN、小程序、flutter等</p>
</li>
</ul>
<h3 id="4、服务端与网络优化"><a href="#4、服务端与网络优化" class="headerlink" title="4、服务端与网络优化"></a>4、服务端与网络优化</h3><ul>
<li><p>CDN 和 DNS 优化</p>
</li>
<li><p>如何减少 http 请求数、减少cookie大小</p>
</li>
<li><p>nginx缓存配置和优化</p>
</li>
<li><p>开启和配置 gzip 压缩</p>
</li>
<li><p>如何开启全站 https</p>
</li>
<li><p>升级 Http2.0 的好处和方法</p>
</li>
</ul>
<h3 id="5、研发流程优化"><a href="#5、研发流程优化" class="headerlink" title="5、研发流程优化"></a>5、研发流程优化</h3><ul>
<li><p>技术调用的方法</p>
</li>
<li><p>前后端接口约定、加快前后端接口联调</p>
</li>
<li><p>前端自动化测试</p>
</li>
<li><p>自动化部署和上线</p>
</li>
<li><p>从研发的整体流程层面梳理出提升研发效率的方式和方法。</p>
</li>
</ul>
<h3 id="6、全链路质量监控体系建设"><a href="#6、全链路质量监控体系建设" class="headerlink" title="6、全链路质量监控体系建设"></a>6、全链路质量监控体系建设</h3><p>主要是对性能优化的结果进行衡量、打分、考核：</p>
<ul>
<li><p>上线前，页面质量及时检测</p>
</li>
<li><p>上线后，页面性能和错误监控</p>
</li>
<li><p>线上运行时，页面的可用性监控</p>
</li>
<li><p>愿生App的性能和错误监控</p>
</li>
</ul>
<h2 id="前端性能优化包括哪些方面"><a href="#前端性能优化包括哪些方面" class="headerlink" title="前端性能优化包括哪些方面"></a>前端性能优化包括哪些方面</h2><h3 id="1、性能优化指标与测量工具"><a href="#1、性能优化指标与测量工具" class="headerlink" title="1、性能优化指标与测量工具"></a>1、性能优化指标与测量工具</h3><ul>
<li><p>行业标准</p>
</li>
<li><p>优化模型</p>
</li>
<li><p>性能测量工具：了解性能情况，并对比</p>
</li>
<li><p>性能相关APIs</p>
</li>
</ul>
<h3 id="2、渲染优化"><a href="#2、渲染优化" class="headerlink" title="2、渲染优化"></a>2、渲染优化</h3><ul>
<li><p>现代浏览器的渲染原理</p>
</li>
<li><p>可优化的渲染环节和方法</p>
</li>
</ul>
<h3 id="3、代码优化"><a href="#3、代码优化" class="headerlink" title="3、代码优化"></a>3、代码优化</h3><ul>
<li><p>JS优化：了解JS的开销、解析、优化方案，以及如何配合V8引擎做更有效的优化。</p>
</li>
<li><p>html优化</p>
</li>
<li><p>css优化</p>
</li>
</ul>
<h3 id="4、资源优化"><a href="#4、资源优化" class="headerlink" title="4、资源优化"></a>4、资源优化</h3><ul>
<li><p>压缩合并</p>
</li>
<li><p>图片格式</p>
</li>
<li><p>图片加载</p>
</li>
<li><p>字体优化</p>
</li>
</ul>
<h3 id="5、构建优化"><a href="#5、构建优化" class="headerlink" title="5、构建优化"></a>5、构建优化</h3><ul>
<li><p>webpack 优化配置</p>
</li>
<li><p>代码拆分</p>
</li>
<li><p>代码压缩</p>
</li>
<li><p>持久化缓存</p>
</li>
<li><p>监测与分析</p>
</li>
<li><p>按需加载</p>
</li>
</ul>
<h3 id="6、传输和加载优化"><a href="#6、传输和加载优化" class="headerlink" title="6、传输和加载优化"></a>6、传输和加载优化</h3><ul>
<li><p>gZip</p>
</li>
<li><p>KeepAlive</p>
</li>
<li><p>HTTP缓存</p>
</li>
<li><p>Service Worker</p>
</li>
<li><p>HTTP&#x2F;2</p>
</li>
<li><p>SSR 服务端渲染</p>
</li>
<li><p>Nginx</p>
</li>
</ul>
<h3 id="7、更多主流优化方案"><a href="#7、更多主流优化方案" class="headerlink" title="7、更多主流优化方案"></a>7、更多主流优化方案</h3><ul>
<li><p>SVG 优化图标</p>
</li>
<li><p>FlexBox 布局</p>
</li>
<li><p>预加载</p>
</li>
<li><p>预渲染</p>
</li>
<li><p>窗口化提高列表性能</p>
</li>
<li><p>骨架屏</p>
</li>
</ul>

  </div>
  <div>
    
      <div 
        class="post-note note-warning copyright" 
        style="margin-top: 42px">
        <p>
          <span style="font-weight: bold;">作者：</span><a 
            target="_blank" 
            rel="nofollow noopener noreferrer" 
            href="/about">
            zwl5670
          </a>
        </p>
        <p>
          <span style="font-weight: bold;">文章链接：</span><a 
            target="_blank" 
            rel="nofollow noopener noreferrer" 
            href="https://zwl5670.gitee.io/2014/08/01/14-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/00-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5/">
            https://zwl5670.gitee.io/2014/08/01/14-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/00-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5/
          </a>
        </p>
        <p><span style="font-weight: bold;">版权声明：</span>本博客所有文章除特别声明外，均采用<a target="_blank" rel="noopener" href="https://creativecommons.org/licenses/by-nc-sa/4.0/deed.zh">CC BY-NC-SA 4.0 协议</a>。转载请注明出处！</p>
      </div>
    
  </div>
</article>
<div class="nav">
  
    <div class="nav-item-prev">
      <a 
        href="/2015/01/01/15-%E5%89%8D%E7%AB%AF%E5%B7%A5%E7%A8%8B%E5%8C%96/%E5%89%8D%E7%AB%AF%E7%9A%84%E5%87%A0%E9%81%93%E9%A2%98%E7%9B%AE/" 
        class="nav-link">
        <i class="iconfont icon-left nav-prev-icon"></i>
        <div>
          <div class="nav-label">上一篇</div>
          
            <div class="nav-title">04-几道面试题 </div>
          
        </div>
      </a>
    </div>
  
  
    <div class="nav-item-next">
      <a 
        href="/2014/08/01/14-%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/03-%E6%B8%B2%E6%9F%93%E4%BC%98%E5%8C%96/" 
        class="nav-link">
        <div>
          <div class="nav-label">下一篇</div>
          
            <div class="nav-title">03-渲染优化 </div>
          
        </div>
        <i class="iconfont icon-right nav-next-icon"></i>
      </a>
    </div>
  
</div>

<div 
  class="card card-content toc-card" 
  id="mobiletoc">
  <div class="toc-header">
  <i 
    class="iconfont icon-menu" 
    style="padding-right: 2px;">
  </i>目录
</div>
<ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5"><span class="toc-text">前端性能优化认知</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BB%80%E4%B9%88%E6%98%AF%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">什么是前端性能优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E9%87%8D%E8%A6%81%E6%80%A7%EF%BC%88%E7%A8%8B%E5%BA%8F%E5%91%98%E8%A7%92%E5%BA%A6%EF%BC%89"><span class="toc-text">性能优化的重要性（程序员角度）</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E9%9D%A2%E8%AF%95"><span class="toc-text">前端性能优化面试</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E6%84%8F%E4%B9%89"><span class="toc-text">性能优化的意义</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%9B%B8%E5%85%B3%E6%A1%88%E4%BE%8B"><span class="toc-text">相关案例</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E8%A1%A5%E5%85%85"><span class="toc-text">补充</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%A6%82%E4%BD%95%E5%AD%A6%E4%B9%A0%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">如何学习性能优化</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AD%A6%E4%B9%A0%E9%9A%BE%E7%82%B9"><span class="toc-text">学习难点</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BC%98%E5%8C%96%E6%A0%87%E5%87%86"><span class="toc-text">优化标准</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%8A%80%E6%9C%AF%E5%82%A8%E5%A4%87%E5%89%8D%E6%8F%90"><span class="toc-text">技术储备前提</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AF%BB%E6%89%BE%E6%80%A7%E8%83%BD%E7%93%B6%E9%A2%88"><span class="toc-text">寻找性能瓶颈</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%A7%BB%E5%8A%A8%E7%AB%AF%E6%8C%91%E6%88%98%E5%A4%9A"><span class="toc-text">移动端挑战多</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%94%B6%E8%8E%B7"><span class="toc-text">收获</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%85%A8%E8%BF%87%E7%A8%8B"><span class="toc-text">前端性能优化全过程</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E9%9D%99%E6%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">1、静态资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E9%A1%B5%E9%9D%A2%E6%B8%B2%E6%9F%93%E6%9E%B6%E6%9E%84%E8%AE%BE%E8%AE%A1%E5%8F%8A%E7%9B%B8%E5%85%B3%E7%9A%84%E6%8A%80%E6%9C%AF%E6%96%B9%E6%A1%88%E9%80%89%E5%9E%8B"><span class="toc-text">2、页面渲染架构设计及相关的技术方案选型</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E5%8E%9F%E7%94%9FApp%E4%BC%98%E5%8C%96%E3%80%81%E6%B7%B7%E5%90%88%E5%BC%80%E5%8F%91%E4%BC%98%E5%8C%96"><span class="toc-text">3、原生App优化、混合开发优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E6%9C%8D%E5%8A%A1%E7%AB%AF%E4%B8%8E%E7%BD%91%E7%BB%9C%E4%BC%98%E5%8C%96"><span class="toc-text">4、服务端与网络优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E7%A0%94%E5%8F%91%E6%B5%81%E7%A8%8B%E4%BC%98%E5%8C%96"><span class="toc-text">5、研发流程优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E5%85%A8%E9%93%BE%E8%B7%AF%E8%B4%A8%E9%87%8F%E7%9B%91%E6%8E%A7%E4%BD%93%E7%B3%BB%E5%BB%BA%E8%AE%BE"><span class="toc-text">6、全链路质量监控体系建设</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%8C%85%E6%8B%AC%E5%93%AA%E4%BA%9B%E6%96%B9%E9%9D%A2"><span class="toc-text">前端性能优化包括哪些方面</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E6%8C%87%E6%A0%87%E4%B8%8E%E6%B5%8B%E9%87%8F%E5%B7%A5%E5%85%B7"><span class="toc-text">1、性能优化指标与测量工具</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E6%B8%B2%E6%9F%93%E4%BC%98%E5%8C%96"><span class="toc-text">2、渲染优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E4%BB%A3%E7%A0%81%E4%BC%98%E5%8C%96"><span class="toc-text">3、代码优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">4、资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E6%9E%84%E5%BB%BA%E4%BC%98%E5%8C%96"><span class="toc-text">5、构建优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E4%BC%A0%E8%BE%93%E5%92%8C%E5%8A%A0%E8%BD%BD%E4%BC%98%E5%8C%96"><span class="toc-text">6、传输和加载优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#7%E3%80%81%E6%9B%B4%E5%A4%9A%E4%B8%BB%E6%B5%81%E4%BC%98%E5%8C%96%E6%96%B9%E6%A1%88"><span class="toc-text">7、更多主流优化方案</span></a></li></ol></li></ol>
</div>
            </main>
            <aside class="right-column">
              <div class="sticky-widescreen">
  
  
    <article class="card card-content toc-card">
      <div class="toc-header">
  <i 
    class="iconfont icon-menu" 
    style="padding-right: 2px;">
  </i>目录
</div>
<ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E8%AE%A4%E7%9F%A5"><span class="toc-text">前端性能优化认知</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BB%80%E4%B9%88%E6%98%AF%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">什么是前端性能优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E9%87%8D%E8%A6%81%E6%80%A7%EF%BC%88%E7%A8%8B%E5%BA%8F%E5%91%98%E8%A7%92%E5%BA%A6%EF%BC%89"><span class="toc-text">性能优化的重要性（程序员角度）</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E9%9D%A2%E8%AF%95"><span class="toc-text">前端性能优化面试</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E7%9A%84%E6%84%8F%E4%B9%89"><span class="toc-text">性能优化的意义</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%9B%B8%E5%85%B3%E6%A1%88%E4%BE%8B"><span class="toc-text">相关案例</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E8%A1%A5%E5%85%85"><span class="toc-text">补充</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%A6%82%E4%BD%95%E5%AD%A6%E4%B9%A0%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96"><span class="toc-text">如何学习性能优化</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AD%A6%E4%B9%A0%E9%9A%BE%E7%82%B9"><span class="toc-text">学习难点</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E4%BC%98%E5%8C%96%E6%A0%87%E5%87%86"><span class="toc-text">优化标准</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%8A%80%E6%9C%AF%E5%82%A8%E5%A4%87%E5%89%8D%E6%8F%90"><span class="toc-text">技术储备前提</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E5%AF%BB%E6%89%BE%E6%80%A7%E8%83%BD%E7%93%B6%E9%A2%88"><span class="toc-text">寻找性能瓶颈</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E7%A7%BB%E5%8A%A8%E7%AB%AF%E6%8C%91%E6%88%98%E5%A4%9A"><span class="toc-text">移动端挑战多</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#%E6%94%B6%E8%8E%B7"><span class="toc-text">收获</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%85%A8%E8%BF%87%E7%A8%8B"><span class="toc-text">前端性能优化全过程</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E9%9D%99%E6%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">1、静态资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E9%A1%B5%E9%9D%A2%E6%B8%B2%E6%9F%93%E6%9E%B6%E6%9E%84%E8%AE%BE%E8%AE%A1%E5%8F%8A%E7%9B%B8%E5%85%B3%E7%9A%84%E6%8A%80%E6%9C%AF%E6%96%B9%E6%A1%88%E9%80%89%E5%9E%8B"><span class="toc-text">2、页面渲染架构设计及相关的技术方案选型</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E5%8E%9F%E7%94%9FApp%E4%BC%98%E5%8C%96%E3%80%81%E6%B7%B7%E5%90%88%E5%BC%80%E5%8F%91%E4%BC%98%E5%8C%96"><span class="toc-text">3、原生App优化、混合开发优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E6%9C%8D%E5%8A%A1%E7%AB%AF%E4%B8%8E%E7%BD%91%E7%BB%9C%E4%BC%98%E5%8C%96"><span class="toc-text">4、服务端与网络优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E7%A0%94%E5%8F%91%E6%B5%81%E7%A8%8B%E4%BC%98%E5%8C%96"><span class="toc-text">5、研发流程优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E5%85%A8%E9%93%BE%E8%B7%AF%E8%B4%A8%E9%87%8F%E7%9B%91%E6%8E%A7%E4%BD%93%E7%B3%BB%E5%BB%BA%E8%AE%BE"><span class="toc-text">6、全链路质量监控体系建设</span></a></li></ol></li><li class="toc-item toc-level-2"><a class="toc-link" href="#%E5%89%8D%E7%AB%AF%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E5%8C%85%E6%8B%AC%E5%93%AA%E4%BA%9B%E6%96%B9%E9%9D%A2"><span class="toc-text">前端性能优化包括哪些方面</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#1%E3%80%81%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96%E6%8C%87%E6%A0%87%E4%B8%8E%E6%B5%8B%E9%87%8F%E5%B7%A5%E5%85%B7"><span class="toc-text">1、性能优化指标与测量工具</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#2%E3%80%81%E6%B8%B2%E6%9F%93%E4%BC%98%E5%8C%96"><span class="toc-text">2、渲染优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#3%E3%80%81%E4%BB%A3%E7%A0%81%E4%BC%98%E5%8C%96"><span class="toc-text">3、代码优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#4%E3%80%81%E8%B5%84%E6%BA%90%E4%BC%98%E5%8C%96"><span class="toc-text">4、资源优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#5%E3%80%81%E6%9E%84%E5%BB%BA%E4%BC%98%E5%8C%96"><span class="toc-text">5、构建优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#6%E3%80%81%E4%BC%A0%E8%BE%93%E5%92%8C%E5%8A%A0%E8%BD%BD%E4%BC%98%E5%8C%96"><span class="toc-text">6、传输和加载优化</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#7%E3%80%81%E6%9B%B4%E5%A4%9A%E4%B8%BB%E6%B5%81%E4%BC%98%E5%8C%96%E6%96%B9%E6%A1%88"><span class="toc-text">7、更多主流优化方案</span></a></li></ol></li></ol>
    </article>
  
  
  <article class="card card-content">
    <div class="recent-posts-card">
  <div class="recent-posts-header">
    <i 
      class="iconfont icon-wenzhang_huaban" 
      style="padding-right: 2px;">
    </i>最近文章
  </div>
  <div class="recent-posts-list">
    
      <div class="recent-posts-item">
        <div class="recent-posts-item-title">2023-03-09</div>
        <a href="/2023/03/09/13-React%E5%9F%BA%E7%A1%80/11-React%20Navive%E5%88%9D%E8%AF%86/"><div class="recent-posts-item-content">11-React Navive初识</div></a>
      </div>
    
      <div class="recent-posts-item">
        <div class="recent-posts-item-title">2023-03-09</div>
        <a href="/2023/03/09/13-React%E5%9F%BA%E7%A1%80/10-AntD%E6%A1%86%E6%9E%B6%E7%9A%84upload%E7%BB%84%E4%BB%B6%E4%B8%8A%E4%BC%A0%E5%9B%BE%E7%89%87%E6%97%B6%E4%BD%BF%E7%94%A8customRequest%E6%96%B9%E6%B3%95%E8%87%AA%E5%AE%9A%E4%B9%89%E4%B8%8A%E4%BC%A0%E8%A1%8C%E4%B8%BA/"><div class="recent-posts-item-content">10-AntD框架的upload组件上传图片时使用customRequest方法自定义上传行为</div></a>
      </div>
    
      <div class="recent-posts-item">
        <div class="recent-posts-item-title">2023-03-09</div>
        <a href="/2023/03/09/13-React%E5%9F%BA%E7%A1%80/09-AntD%E6%A1%86%E6%9E%B6%E7%9A%84upload%E7%BB%84%E4%BB%B6%E4%B8%8A%E4%BC%A0%E5%9B%BE%E7%89%87%E6%97%B6%E9%81%87%E5%88%B0%E7%9A%84%E4%B8%80%E4%BA%9B%E5%9D%91/"><div class="recent-posts-item-content">09-AntD框架的upload组件上传图片时遇到的一些坑</div></a>
      </div>
    
      <div class="recent-posts-item">
        <div class="recent-posts-item-title">2023-03-09</div>
        <a href="/2023/03/09/13-React%E5%9F%BA%E7%A1%80/08-Ant%20Design%E7%9A%84%E5%9F%BA%E6%9C%AC%E4%BD%BF%E7%94%A8/"><div class="recent-posts-item-content">08-Ant Design的基本使用</div></a>
      </div>
    
  </div>
</div>
  </article>
  
  
</div>
            </aside>
          </div>
        </div>
      </div>
    </div>
     
    <footer class="footer">
  <div class="footer-container">
    <div>
      <div class="footer-dsc">
        <span>
          Copyright ©
          
            2023
          
          
        </span>
        &nbsp;
        <a 
          href="/" 
          class="footer-link">
          前端面试
        </a>
      </div>
    </div>

    
      <div class="footer-dsc">
        
          Powered by
          <a 
            href="https://hexo.io/" 
            class="footer-link" 
            target="_blank" 
            rel="nofollow noopener noreferrer">
            &nbsp;Hexo
          </a>
        
        
          <span>&nbsp;|&nbsp;</span>
        
        
          Theme -
          <a 
            href="https://github.com/theme-kaze" 
            class="footer-link" 
            target="_blank"
            rel="nofollow noopener noreferrer">
            &nbsp;Kaze
          </a>
        
      </div>
    
    
    
    
</footer>
 
    
  <a 
    role="button" 
    id="scrollbutton" 
    class="basebutton" 
    aria-label="回到顶部">
    <i class="iconfont icon-arrowleft button-icon"></i>
  </a>

<a 
  role="button" 
  id="menubutton"
  aria-label="menu button"
  class="basebutton">
  <i class="iconfont icon-menu button-icon"></i>
</a>
<a 
  role="button" 
  id="popbutton" 
  class="basebutton" 
  aria-label="控制中心">
  <i class="iconfont icon-expand button-icon"></i>
</a>
<a 
  role="button" 
  id="darkbutton" 
  class="basebutton darkwidget" 
  aria-label="夜色模式">
  <i class="iconfont icon-weather button-icon"></i>
</a>
<a 
  role="button" 
  id="searchbutton" 
  class="basebutton searchwidget" 
  aria-label="搜索">
  <i class="iconfont icon-search button-icon"></i>
</a> 
     
     
     
      <script>
  var addImgLayout = function () {
    var img = document.querySelectorAll('.post-content img')
    var i
    for (i = 0; i < img.length; i++) {
      var wrapper = document.createElement('a')
      wrapper.setAttribute('href', img[i].getAttribute('data-src'))
      wrapper.setAttribute('aria-label', 'illustration')
      wrapper.style.cssText =
        'width: 100%; display: flex; justify-content: center;'
      if (img[i].alt) wrapper.dataset.caption = img[i].alt
      wrapper.dataset.nolink = true
      img[i].before(wrapper)
      wrapper.append(img[i])
      var divWrap = document.createElement('div')
      divWrap.classList.add('gallery')
      wrapper.before(divWrap)
      divWrap.append(wrapper)
    }
    baguetteBox.run('.gallery')
  }
</script>
<script>
  loadScript(
    "/js/lib/lightbox/baguetteBox.min.js",
    addImgLayout
  )
</script>
 
     
     
    <script src="/js/main.js"></script> 
     
    
      <script>
        var addLazyload = function () {
          var observer = lozad('.lozad', {
            load: function (el) {
              el.srcset = el.getAttribute('data-src')
            },
            loaded: function (el) {
              el.classList.add('loaded')
            },
          })
          observer.observe()
        }
      </script>
      <script>
        loadScript('/js/lib/lozad.min.js', addLazyload)
      </script>
    
    <script src="//instant.page/5.1.0" type="module"
      integrity="sha384-by67kQnR+pyfy8yWP4kPO12fHKRLHZPfEsiSXR8u2IKcTdxD805MGUXBzVPnkLHw"></script>
    
    
  </body>
</html>
